<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            height: 2000px;
        }
    </style>
</head>

<body>

</body>
<script>
    // 防抖是只执行最后一次
    // 节流是控制执行次数
    //节流的作用： 控制高频时间的执行次数
    // window.onscroll = function(){
    //     // console.log('123');
    //     if(flag){
    //         setTimeout(()=>{
    //             console.log('hello world');
    //             flag = true;
    //         },500)
    //     }
    //     flag = false;
    // }


    // 封装后的
    // let flag = true；
    window.onscroll = throttle(function () {
        console.log('hello world');
    }, 500)

    function throttle(fn, delay) {
        let flag = true;
        return function () {
            if (flag) {
                setTimeout(() => {
                    fn.call(this);
                    falg = true;
                }, delay)
            }
        }
        flag = false
    }

</script>

</html>